#include<bits/stdc++.h>
using namespace std;
#define all(x) (x).begin(),(x).end()
#define rall(x) (x).rbegin(),(x).rend()
const int N=2e5+10;
#define INF 0x3f3f3f3f;
typedef long long int ll;
#define close(); std::ios::sync_with_stdio(false);cin.tie(0),cout.tie(0);
//----------------------------------------------------------------------------//
pair<int,int> a[N];//fi is start  se is end
int n,k,w,d;
void solve()
{
	cin>>n>>k>>d>>w;//人数，每个疫苗包装的计量数，疫苗在冰箱外的存活时间，每个患者的等待时间
	for(int i=0;i<n;i++)
	{
		int fi;
		cin>>fi;
		a[i].first=fi;
		a[i].second=fi+w;
	}
	
	int id=0;//枚举当前人
	int ans=0;

	while(id<n)
	{
		int num=1;
		int cur=id;
		while(a[id+1].first<=a[cur].second+d&&num<k) num++,id++;

		id++;
		ans++;

	}
	cout<<ans<<'\n';
	
}

int main()
{
	close();
	int T; cin>>T;
	while (T--) solve();
	return 0;
}